// 已知一个长度为 n 的数组，预先按照升序排列，经由 1 到 n 次 旋转 后，得到输入数组。例如，原数组 nums = [0,1,2,4,5,6,7] 在变化后可能得到：
// 若旋转 4 次，则可以得到 [4,5,6,7,0,1,2]
// 若旋转 7 次，则可以得到 [0,1,2,4,5,6,7]
// 注意，数组 [a[0], a[1], a[2], ..., a[n-1]] 旋转一次 的结果为数组 [a[n-1], a[0], a[1], a[2], ..., a[n-2]] 。

// 给你一个元素值 互不相同 的数组 nums ，它原来是一个升序排列的数组，并按上述情形进行了多次旋转。请你找出并返回数组中的 最小元素 。



class Solution {
    public int findMin(int[] nums) {
        int len = nums.length;
        if(nums[len-1]>nums[0])
            return nums[0];
        int left = 0;
        int right = len-1;
        int mid = 0;
        while(left<=right)
        {
            mid = (left+right)/2;
            if(left==right)
                return nums[mid];
            if(nums[mid]>nums[len-1])
            {
                left = mid+1;
            }
            else if((nums[mid]<nums[len-1]) && (nums[mid]>nums[mid-1]))
            {
                right = mid-1;
            }
            else if((nums[mid]<nums[len-1])&&(nums[mid]<nums[mid-1]))
            {
                return nums[mid];
            }
        }
        return 0;
    }
}